home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus Special 24 / AMIGAplus Sonderheft 24 (2000)(Falke)(DE)[!].iso / PublicDomain / Anwendungen / MT-RechnungIII / Rexx / FWUmschlagWS_DL.outrexx < prev    next >
Text File  |  1998-11-16  |  3KB  |  154 lines

  1. /*
  2. ** Druck-, Vorschau, Sichern eines Briefumschlags(Warensendung) an den Warenempfänger mit Hilfe von FinalWriter
  3. ** $VER: FWUmschlagWS_DL.outrexx V1.00 (16.11.98)
  4. */
  5.  
  6. PARSE ARG ARexxPort;
  7.  
  8. ADDRESS VALUE ARexxPort;
  9. OPTIONS RESULTS;
  10.  
  11. FWVorlage    = "FWDokumente/UmschlagWS_DL.fw";
  12. FWDokument    = "t:UmschlagWS_DL.fw";
  13. FWPort        = "FINALW."
  14.  
  15. LF                = '0a'x;                            /* Zeilenvorschub                */
  16.  
  17. Gefunden = 0;
  18. DO i = 1 TO 20 WHILE(Gefunden = 0)
  19.     IF show(ports, (FWPort || i)) THEN
  20.         DO;
  21.             Gefunden = 1;
  22.             FWPort     = FWPort || i;
  23.         END;
  24. END;
  25.  
  26. IF Gefunden = 0 THEN
  27.     DO;
  28.         ES_TITLE                = "Warnung";
  29.         ES_TEXTFORMAT        = "FinalWriter ist nicht aktiv, bitte starten sie dieses" || LF || "und versuchen Sie es erneut";
  30.         ES_GADGETFORMAT    = "Abbrechen";
  31.         EASY_REQUEST;
  32.         EXIT;
  33.     END;
  34.  
  35. /* Original FW-Dokument nach t: kopieren, um ein versehentliches überschreiben */
  36. /* dieser Vorlage zu verhindern */
  37. GET_REXXPATH;
  38. FWVorlage        = MTR_RESULT || FWVorlage;
  39. ADDRESS COMMAND "copy" FWVorlage FWDokument;
  40.  
  41. /* Oberfläche sperren */
  42. LOCKGUI;
  43.  
  44. /* Art ermitteln: 0 = Drucken, 1 = Vorschau, 2 = Speichern */
  45. PRINTSTATE;
  46. Druckart = MTR_RESULT;
  47.  
  48. Ende_Kennzeichen = 'N';
  49.  
  50. /* Suchen der zu druckenden Daten */
  51. PRINTFIND;
  52.  
  53. DO WHILE( MTR_RESULT > 0 & Ende_Kennzeichen = 'N');
  54.     ADDRESS VALUE FWPort;
  55.     SCREENTOFRONT;
  56.  
  57.     CALL DatenAufbereiten;
  58.     SELECT;
  59.         WHEN Druckart = 0 THEN    /* Drucken    */
  60.             DO;
  61.                 ADDRESS VALUE FWPort;
  62.                 PRINT;
  63.                 ADDRESS VALUE ARexxPort;
  64.                 MTSCREENTOFRONT;
  65.             END;
  66.         WHEN Druckart = 1 THEN    /* Vorschau    */
  67.             ADDRESS VALUE ARexxPort;
  68.         WHEN Druckart = 2 THEN    /* Sichern    */
  69.             DO;
  70.                 ADDRESS VALUE FWPort;
  71.                 SAVEAS;
  72.                 ADDRESS VALUE ARexxPort;
  73.                 MTSCREENTOFRONT;
  74.             END;
  75.         OTHERWISE
  76.             DO;
  77.                 ES_TITLE                = "Warnung";
  78.                 ES_TEXTFORMAT        = "Druckart wird nicht unterstützt!";
  79.                 ES_GADGETFORMAT    = "Ok";
  80.                 EASY_REQUEST;
  81.                 Ende_Kennzeichen    = 'J';
  82.             END;
  83.     END;
  84.  
  85.     PRINTFIND;
  86. END;
  87.  
  88. /* WordWorth-Datei aus t: wieder entfernen */
  89. ADDRESS COMMAND "delete" FWDokument;
  90.  
  91. /* Oberfläche wieder entsperren */
  92. ADDRESS VALUE ARexxPort;
  93. FREEGUI;
  94.  
  95. EXIT;
  96.  
  97. DatenAufbereiten:
  98.     CLEARDOC;
  99.     OPEN FWDokument;
  100.  
  101.     DruckString    = OB.OFFICE.ADDRESS.ADDRESS.2 || LF;
  102.     i = INDEX( DruckString, LF);
  103.     IF i > 0 THEN
  104.         DO;
  105.             DruckTeil    = LEFT( DruckString, (i - 1) );
  106.             DruckString = SUBSTR(DruckString, (i + 1) );
  107.             i = INDEX( DruckString, LF);
  108.         END;
  109.     ELSE
  110.         DruckTeil    = DruckString;
  111.  
  112.     SETFIND CASE NO WRAP YES;
  113.     FIND "<SENDER.ADDRESS.2>";
  114.     FINDNEXT;
  115.     STATUS LinePos;
  116.     PARSE VAR RESULT BegLine BegPosition EndLine EndPosition;
  117.     TYPE DruckTeil;
  118.  
  119.     DO WHILE( i > 0 );
  120.         DruckTeil    = LEFT( DruckString, (i - 1) );
  121.         DruckString = SUBSTR(DruckString, (i + 1) );
  122.         BegLine        = BegLine + 1;
  123.         MoveToLine BegLine 0;
  124.         TYPE DruckTeil;
  125.         i = INDEX( DruckString, LF);
  126.     END;
  127.  
  128.     DruckString    = OB.CONSIGNEE.CUSTOMER.ADDRESS.ADDRESS.2 || LF;
  129.     i = INDEX( DruckString, LF);
  130.     IF i > 0 THEN
  131.         DO;
  132.             DruckTeil    = LEFT( DruckString, (i - 1) );
  133.             DruckString = SUBSTR(DruckString, (i + 1) );
  134.             i = INDEX( DruckString, LF);
  135.         END;
  136.     ELSE
  137.         DruckTeil    = DruckString;
  138.  
  139.     FIND "<RECEIVER.ADDRESS.2>";
  140.     STATUS LinePos;
  141.     PARSE VAR RESULT BegLine BegPosition EndLine EndPosition;
  142.     TYPE DruckTeil;
  143.  
  144.     DO WHILE( i > 0 );
  145.         DruckTeil    = LEFT( DruckString, (i - 1) );
  146.         DruckString = SUBSTR(DruckString, (i + 1) );
  147.         BegLine        = BegLine + 1;
  148.         MoveToLine BegLine 0;
  149.         TYPE DruckTeil;
  150.         i = INDEX( DruckString, LF);
  151.     END;
  152. RETURN;
  153.  
  154.